testsuite: Improve coverage for GdkDisplayManager
authorMatthias Clasen <mclasen@redhat.com>
Sat, 31 Oct 2020 19:15:19 +0000 (15:15 -0400)
committerMatthias Clasen <mclasen@redhat.com>
Mon, 2 Nov 2020 02:23:35 +0000 (21:23 -0500)
testsuite/gdk/displaymanager.c [new file with mode: 0644]
testsuite/gdk/meson.build

diff --git a/testsuite/gdk/displaymanager.c b/testsuite/gdk/displaymanager.c
new file mode 100644 (file)
index 0000000..ce7c0d9
--- /dev/null
@@ -0,0 +1,55 @@
+#include <gtk/gtk.h>
+
+static void
+test_basic (void)
+{
+  GdkDisplayManager *manager;
+  GdkDisplay *d, *d2;
+  GSList *list;
+
+  manager = gdk_display_manager_get ();
+  g_assert_nonnull (manager);
+
+  d = gdk_display_manager_get_default_display (manager);
+  g_assert_nonnull (d);
+  g_object_get (manager, "default-display", &d2, NULL);
+  g_assert_true (d == d2);
+  g_object_unref (d2);
+
+  list = gdk_display_manager_list_displays (manager);
+  g_assert_nonnull (g_slist_find (list, d));
+  g_slist_free (list);
+}
+
+static void
+test_set_default (void)
+{
+  GdkDisplayManager *manager;
+  GdkDisplay *d, *d2;
+  const char *name;
+
+  manager = gdk_display_manager_get ();
+  g_assert_nonnull (manager);
+
+  d = gdk_display_manager_get_default_display (manager);
+  name = gdk_display_get_name (d);
+  d2 = gdk_display_manager_open_display (manager, name);
+  g_object_set (manager, "default-display", d2, NULL);
+
+  d = gdk_display_manager_get_default_display (manager);
+  g_assert_true (d == d2);
+}
+
+int
+main (int argc, char *argv[])
+{
+  g_test_init (&argc, &argv, NULL);
+
+  /* Open default display */
+  gdk_display_open (NULL);
+
+  g_test_add_func ("/displaymanager/basic", test_basic);
+  g_test_add_func ("/displaymanager/set-default", test_set_default);
+
+  return g_test_run ();
+}
index aa93f8384d74845e6fd7e007f174f2b2039aebf4..008b6269a277e348377a849a2166557de1a62ab4 100644 (file)
@@ -6,6 +6,7 @@ tests = [
   'cairo',
   'clipboard',
   'display',
+  'displaymanager',
   'encoding',
   'keysyms',
   'memorytexture',